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CLAIMS : 

1. A data searching system comprising: 

a database for storing a plurality of pieces of data; 

a search tab 1ft for storing at least one pi fine, of 
data i*hich has been selected by the database; and 
5 an address pointer table for storing location 

information Indicating an entry address of each piece of data 
stored in the search table and/or relationship information among 
entry addresses of pieces of data stored in the search table, 

2. The data searching system according to claim 1, 
10 wherein the address pointer table comprises a plurality of memory 

blocks each having a fixed length on a recording medium, wherein 
the memory blocks are located at consecutive addresses, 

wherein each of the memory blocks comprises ; 

a first area for storing an entry address indicating 
15 a location of a corresponding piece of data stored in the search 
table ; and 

a second area for storing one of a uexL block address 
and a bottom-indicating flag, the next block address indicating 
an addxess of d iueiuuiy block slujLiiiy dald following Lhe 
2 0 corresponding piece of data, and the bottom- indicating flag 
iiidicaliuy LhaL a cuiieiiL lueuiui-y block is a buLLunl of a list, 
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3* The data searching system according to claim 1, 
further comprising: 

a controller controlling such that the search table 
is searched for a desired piece of data before the database and , 
5 if a hit is found in the search table, then a found piece of 
data is used as a search result, and if no hit: is found in the 
search table, then the database is searched for the desired piece 
of data and a found piftCft of data is nsftd as a search result 
and is registered into the search table, wherein a piece of data 
10 with low retrieved frequency is deleted from the search table 
according to a predetermined condition and all linked memory 
blocks related to the deleted piece of data are released into 
available memory blocks > 



4. h packet processing system comprising: 
15 a microprocessor; 

a routing table; 

a memory storing a search table which is used to 
Increase in search speed lor packet lorwarding; and 

an address pointer table for storing location 
20 information indicating an entry address of each piece of data 
stored in the search table and/ or relationship information among 
entry addresses of pieces of data stored in the search table* 



5, A packet processing system comprising: 
a microprocessor: 
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a routing table ; 

a searcher having a search memory connected tharftt n , 
wherein the search memory stores a search table which is used 
to Increase in search speed for packet forwarding; and 
5 an address pointer table for storing location 

information indicating an entry address of each piece of data 
stored in the search table and/or relationship information among 
entry addresses of pieces of data stored in the search table. 

6. The packet processing system according to claim 5, 
10 wherein the address pointer table is provided in a main memory 

of the microprocessor. 

7. The packet processing system according to claim 5, 
wherein the address pointer table is provided in the search 
memory . 

15 8. The packet processing system according to claim 5, 

wherein Lhe address pointer table comprises a plurality of memory 
blocks each having a fixed length on a recording medium, wherein 
the memory blocks are located at consecutive addresses, 
wherein each of the memory blocks comprises • 

20 a fir at area fur storing an entry address indicating 

a location of a corresponding piece of data stored in the search 
table; and 

3 second area for storing one of a next block address 
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and a. bottom- indicating flag, the next block address Indicating 
an address o£ a memory block storing data following the 
corresponding piece ol data, and the bottom- indicating flay 
indicating that a current memory block is a bottom of a list. 

5 9 . A control method for controlling a packet 

processing System comprising: 
a microprocessor; 
a routixiy table; 

a searcher having a search memory connected thereto, 
10 wherein the search memory stores a search table which is used 
to Increase in search speed for packet forwarding; and 

an address pointer table for storing location information 
indicating an entry address of each piece of data stored in the 
search table and/ or relationship Information among entry 
15 addresses of pieces of data stored in the search table, 
the control method comprising the steps of: 

a) when the routing table has been updated, 
accessing the address pointer table based on contents of an entry 
to be changed to obtain location information of the entry to 

20 be changed and entries related to the entry to be changed In 
the search memory; and 

b) changing the entry and related entries so as to 
be consistent with the routing table. 



10. A system comprising: 
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a first memory for retrievabiy storing a plurality 

of entries; 

a second memory for storing a copy o£ an entry that 
has been retrieved from the first memory to retrievabiy store 
5 a plurality of retrieved entries; 

a third memory for storing a list of retrieved 
entries which are linked from a leading one to a bottom one; 
and 

a data controller for accessing a desired retrieved 
10 entry by referring to the list stored in the third memory. 

11. The system according to claim 10, wherein the data 
controller processes the desired retrieved entry so as to be 
consistent with a corresponding entry stored in the first memory 
when the corresponding entry has been processed. 

15 12* The system according to claim 10 , wherein each ol 

the entries stored in the first memory has a first indicator 
and a second indicator, the first indicator indicating which 
one of a single entry and an aggregated entry the entry relates 
to, wherein the aggregated entry has a plurality ol single 

20 entries belonging thereto , and the second indicator indicating 
a leading address of the list in the third memory. 

13. The System according Lu claim 10, wherein the list 
of retrieved entries comprises a plurality of memory blocks each 
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corresponding to the retrieved entries , each of the memory block3 
comprising an address of a corresponding retrieved entry in the 
second memory and a next pointer indicating one of an address 
of a next memory block following the memory block and an address 
5 of the memory block itself. 

14. The system according to claim 12, wherein, when an 
aggregated entry stored in thft first, memory 1s designated , the 
data controller accesses the third memory depending on the second 
indicator of the aggregated entry to trace thft list of single 

10 entries related to the aggregated entry so as to access the single 
entries related to the aggregated entry. 

15. The system according tr> nlaim 1 4 , whp.rp.in, whfin 
contents o£ the lirst memory have been updated, the data 
controller processes the single entries related tn tha 

15 aggregated entry so as to be consistent with the contents of 
the first memory. 

16. A packet switching system comprising: 

a routing table for retrievably storing a plurality 
of routing entries; 
2 0 a riuw table JTor storing a copy ol a routing entry 

indicating a packet flow that has been retrieved from the routing 
L^ble Lu i.ttliiavdbiy store a plurality o£ retrieved packet flows ; 

an address pointer table for storing a list of 
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retrieved packet flows which arc linked from a leading one to 
a bottom one: 

a search processor for accessing a desired 
retrieved packet flow in the tlow table by referring to the list 

5 stored in the address pointer table; and 

a microprocessor performing a packet routing 

control, 

17. The packet switching system according to claim 16, 
vhftrAin, vhAn a routing An try has bAAn dA.si gnatftd to bp processed 

10 according to predetermined routing processing, the search 

prnnfl.qsnr pronASSAS a corrA.sponding rAtri eved packet flow in 
the flow table so as to be consistent with the designated routing 
An try storpd in fhp. routing tahlft. 

18. The packet switching system according to claim 16, 
15 wherein each of the routing entries stored in the routing table 

has a fi r.gt indi naror and a second i ndi r.zitor , the first i ndi cator 
indicating which one of a single packet flow and an aggregated 
packet flow the renting entry rplates to, wherein the aggregated 
packet flow has a plurality of single packet flows belonging 
20 thereto, and the second indicator indicating a leading address 
of the list in the address pointer table. 

19. The packet switching system according to claim 16, 
wherein the list of retrieved packet flows comprises a plurality 
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of memory blocks each corresponding to the retrieved packet flows , 
each of the memory blocks comprising an address of a 
corresponding retrieved packet flow in the flow table and a next 
pointer indicating one of an address of a naxt memory block 
5 following the memory block and an address of the memory block 
itself. 

2fl. The packet switching system according to claim 18, 
wherein, when an aggregated routing entry stored in the routing 
table is designated, the search processor accesses the address 
10 pointer table depending on the second indicator of Lhe ayyreyaLed 
routing entry to trace the list of single packet flows related 
to the aggregated routing entry so as Lo access Lhe single packet 
flows related to the aggregated routing entry. 

21. The packet switching system according to claim 20, 
15 wherein the search processor processes Lhe sinyle packet flows 

related to the aggregated routing entry so as to be consistent 
with the routing table when the rouLiay table has been updated, 

22. A packet switehiny me thud comprising the steps of; 

a) retrievably storing a plurality of routing 
20 enLxies in a. ruuLiny Lable; 

b) storing a copy of a routing entry indicating a 
packeL flow LhaL lids been xeLxieved from the routing table Lu 
retrievably store a plurality of retrieved packet flows in a 
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c) storing a list of retrieved packet flows which 
are linked from a leading one to a bottom one in an address pointer 
table; and 

5 d) accessing a desired retrieved packet flow in the 

flow table by referring to the list stored in the address pointer 
table - 

23. The packet switching method according to claim 22, 
wherein the step (d) comprises the steps o£: 
10 when a packet flow corresponding to a received 

packet fails to be found in the search tabid, searching the 
routing table foi the packet flow; 

registering the found packet flow as a routing 
result into the search table; 
15 determining whether the found packet flow is a micro 

flow belonging to an aggregated flow; 

when the found packet flow is the micro flow, 
searching the search table for a bottom retrieved packet flow 
of the list corresponding to the aggregated flow; 
20 adding the found packet flow to the bottom retrieved 

packet flow stored in the search tabid; and 

when the found packet flow is not the micro flow, 
storing an address of the found packet flow in the search table 
into a corresponding routing entry in the routing table. 
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24. The packet switching method according to claim 22 , 
wherein the step (d) comprises the steps of: 

when an aggregated routing entry has been 
designated to be deleted, deleting each of the rAtriftvad packet. 
5 flows included in a list related to the aggregated routing entry 
from the address pointer table until finding a bottom retrieved 
packet flow of the list; 

rp.lAasing a chain of the retrieved packet flows 
formed in the address pointer table to make them available ; 
10 deleting a retrieved packet flow corresponding to 

the aggregated routing entry from the flow table; and 

deleting the aggregated routing entry from the 
routing table. 



